# Sequence Generator

MINI PROJECT

DIGITAL DESIGN AND CIRCUIT OPTIMIZATION

# TABLE OF CONTENTS

| Table of Contents            | . 1 |
|------------------------------|-----|
| Project Team Overview        | . 2 |
| Team Members & Roles         | 2   |
| Team Members & Roles         | 2   |
| Project Repository           |     |
| Introduction                 |     |
| Problem Statement            | . 3 |
| Module Description           | . 3 |
| Sequence Generator           | 3   |
| Sequence Generator Testbench | 4   |
| Explanation                  | . 5 |
| Gtkwave Output               | 5   |



# PROJECT TEAM OVERVIEW

# TEAM MEMBERS

| NAME                     | SRN           |
|--------------------------|---------------|
|                          |               |
| Paddhariya Mohit Kaushik | PES1UG24CS816 |
| C S Dipak                | PES1UG23CS907 |
| Chennupati Gundeep       | PES1UG23CS160 |
| Chemiupati Gundeep       | FE310423C3100 |
| Bysani Niravann          | PES1UG23CS152 |

# TEAM MEMBERS & ROLES

The project was led by **Mohit Paddhariya**, who served as the **Team Leader** and was responsible for most of the development, planning, and execution. Mohit took charge of overseeing the entire project from start to finish, ensuring that all aspects were completed efficiently and effectively.

The remaining team members contributed to supporting roles, assisting with specific tasks as needed:

- Chennupati Gundeep, assisting with initial research and basic setup tasks.
- CS Dipak, contributing to data collection and minor bug fixing.
- Bysani Niravann, helping with documentation and some testing efforts.

# PROJECT REPOSITORY

You can explore the project's source code on the official repository:

**GitHub Repository Link** 



## INTRODUCTION

In digital design, a sequence generator is a circuit that produces a specific sequence of binary numbers over time. It's useful for creating patterns or signals that are needed in various digital systems, like clocks, counters, or communication devices. This document provides a detailed description and implementation of a 3-bit sequence generator using a simple state machine.

## PROBLEM STATEMENT

Design and implement a sequence generator. A sequence generator produces a series of binary outputs based on a defined set of states. In this case, the generator is designed to output a 3-bit sequence that cycles through four predefined states.

#### MODULE DESCRIPTION

# SEQUENCE GENERATOR

This module generates a 3-bit sequence output based on a simple state machine. The state transitions are controlled by a clock signal and can be reset asynchronously. The sequence generated cycles through four predefined states, outputting specific 3-bit values for each state.

# CODE

```
module sequence_generator(
   input clk,
   input reset,
   output reg [2:0] seq_out
);
   reg [1:0] state;
   parameter S0 = 3'b101, S1 = 3'b110, S2 = 3'b011, S3 = 3'b001;

   always @(posedge clk or posedge reset) begin
   if (reset)
      state <= 2'b00;
   else
      state <= state + 1;
   end

   always @(state) begin
   case(state)</pre>
```



```
2'b00: seq_out = S0;

2'b01: seq_out = S1;

2'b10: seq_out = S2;

2'b11: seq_out = S3;

default: seq_out = S0;

endcase

end

endmodule
```

## **TESTBENCH**

The testbench module, tb\_sequence\_generator, simulates the clock and reset signals to verify the functionality of the sequence generator. It includes a clock generation process and initializes the reset signal to check the output sequence.

## CODE

```
module tb_sequence_generator;
 reg clk;
 reg reset;
 wire [2:0] seq_out;
 sequence_generator uut (.clk(clk), .reset(reset), .seq_out(seq_out));
 initial begin
    clk = 0;
   forever #5 clk = \sim clk;
 end
 initial begin
    $dumpfile("sequence_generator.vcd");
    $dumpvars(0, tb_sequence_generator);
    reset = 1; #10; reset = 0;
    #100;
    $finish;
 end
endmodule
```



# **EXPLANATION**

A sequence generator produces a repeating or predictable series of bits, often used in electronics for tasks like timing or data control. It starts from an initial value and transitions between states with a clock signal. The testbench checks the functionality by generating signals and capturing the output.

# GTKWAVE OUTPUT



